import './index.scss'
import { Card, Form, Input, Button, message } from 'antd'
import logo from '@/assets/logo.png'
import {useDispatch} from "react-redux"
import {fetchToken} from "@/store/module/userStore.js"
import {useNavigate} from "react-router-dom"

const Login = () => {
    //获取dispatch对象
    const dispatch=useDispatch()
    //跳转对象
    const navigate=useNavigate()
    // 点击登录按钮时触发 参数values即是表单输入数据
    const onFinish =async (formValue)=> {
        console.log(formValue)
        //等待请求完成后执行跳转操作
        await dispatch(fetchToken(formValue))
        //跳转到主页面
        navigate("/")
        message.success("登录成功")
    }

    return (
        <div className="login">
            <Card className="login-container">
                <img className="login-logo" src={logo} alt="" />
                {/* 登录表单 */}
                <Form validateTrigger={['onBlur']} onFinish={onFinish}>
                    <Form.Item
                        name="mobile"
                        rules={[
                            { required: true, message: '请输入手机号' },
                            {
                                pattern: /^1[3-9]\d{9}$/,
                                message: '手机号码格式不对'
                            }
                        ]}
                    >
                        <Input size="large"  defaultValue="13811111111" placeholder="请输入手机号" />
                    </Form.Item>
                    <Form.Item
                        name="code"
                        rules={[
                            { required: true, message: '请输入验证码' },
                        ]}
                    >
                        <Input size="large" defaultValue="246810" placeholder="请输入验证码" maxLength={6} />
                    </Form.Item>
                    <Form.Item>
                        <Button type="primary" htmlType="submit" size="large" block>
                            登录
                        </Button>
                    </Form.Item>
                </Form>
            </Card>
        </div>
    )
}

export default Login